// Problem: 
// Contest: 
// URL: 
// Memory Limit: 
// Time Limit: 
// #pragma GCC optimize("Ofast")
// #pragma GCC optimize("unroll-loops")
// #pragma GCC target("sse,sse2,sse3,ssse3,sse4,popcnt,abm,mmx,avx,avx2,tune=native")
#include<bits/stdc++.h>
using namespace std;
#define int long long
inline int read(){
	int s=0,w=1;
	char ch=getchar();
	while(ch<'0'||ch>'9'){if(ch=='-')w=-1;ch=getchar();}
	while(ch>='0'&&ch<='9') s=s*10+ch-'0',ch=getchar();
	return s*w;
}
vector<int> v(1001),dp(1001);
void zs()
{
	for(int i=2;i<=500;i++)
	{
		if(!v[i])
			for(int j=2;i*j<=1000;j++)
				v[i*j]=1;
	}
}
signed main()
{
	int t=1;
//	cin>>t;
	while(t--)
	{
		zs();
		int n;
		cin>>n;
		dp[0]=1;
		for(int i=2;i<=n;i++)
		{
			if(!v[i])
				for(int j=i;j<=n;j++)
				{
					dp[j]+=dp[j-i];
				}
		}
		cout<<dp[n];
	}
	return 0;
}
